package cn.iocoder.yudao.module.wms.dal.dataobject.otherin;

import lombok.*;

import java.time.LocalDate;
import java.util.*;
import java.math.BigDecimal;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;

/**
 * 通用入库单 DO
 *
 * @author 芋道源码
 */
@TableName("wms_other_in")
@KeySequence("wms_other_in_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库，可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class OtherInDO extends BaseDO {

    /**
     * 序号
     */
    @TableId(type = IdType.ASSIGN_ID)
    private Long id;
    /**
     * 单据类型
     */
    private Long docId;
    /**
     * 单据日期
     */
    private LocalDate docDate;
    /**
     * 编号
     */
    private String code;
    /**
     * 交易日期
     */
    private LocalDate transactionDate;
    /**
     * 制单人
     */
    private Long operateUser;
    /**
     * 制单部门
     */
    private Long operateDept;
    /**
     * 制单日期
     */
    private LocalDate operateDate;
    /**
     * 审核人
     */
    @TableField(updateStrategy = FieldStrategy.ALWAYS)
    private Long approveUser;
    /**
     * 审核日期
     */
    @TableField(updateStrategy = FieldStrategy.ALWAYS)
    private LocalDate approveDate;
    /**
     * 业务合计数量
     */
    private BigDecimal businessSumQty;
    /**
     * 成本合计金额
     */
    private BigDecimal costSumAmt;
    /**
     * 审核状态
     *
     * 枚举 {@link TODO approve_status 对应的类}
     */
    private Boolean approveStatus;
    /**
     * 附件
     */
    private String annex;
    /**
     * 备注
     */
    private String remark;
    /**
     * 乐观锁
     */
    private Long revision;

}